Page({
  data: {
    name: '',
    gender: 1,
    mobile: '',
    idcardFrontUrl: '',
    idcardBackUrl: ''
  },
  onLoad({ point, building, room, id}) {
    if(id) {
      this.getHouseDetail(id)
      // 修改页面标题
      wx.setNavigationBarTitle({
        title :'编辑房屋信息'
      })
    }else {
      // 添加
      // point: 上个页面传递过来的小区名
      // building: 上个页面传递过来的楼号
      // room: 上个页面传递过来的房间号
      this.setData({
        point, building, room
      })
    }
  },
  // 获取房屋详情信息
  async getHouseDetail(id) {
    const {code, data} = await wx.http.get(`/room/${id}`)
    if (code !== 10000) return wx.utils . toast()
    // 接口调用成功
    this.setData({
      ...data
    })
  },
  removePicture(ev) {
    // 移除图片的类型（身份证正面或反面）
    const type = ev.mark.type
    this.setData({
      [type]: ''
    })
  },
  // 验证业主姓名
  validName() {
    // 验证业主姓名（必须为汉字）
    const reg = /^[\u4e00-\u9fa5]{2,5}$/
    // 验证业主姓名
    const valid = reg.test(this.data.name.trim())
    // 验证结果提示
    if (!valid) wx.utils.toast('请填写真实中文姓名!')
    // 返回验证结果
    return valid
  },
  // 验证手机号
  validMobile() {
    // 验证手机号
    const reg = /^1[3-8]\d{9}$/
    const valid = reg.test(this.data.mobile.trim())
    // 验证结果提示
    if (!valid) wx.utils.toast('请填写正确的手机号码!')
    // 返回验证结果
    return valid
  },
  // 身份证照片的校验
  validPicture() {
    const valid = !!this.data.idcardFrontUrl && !!this.data.idcardBackUrl
    if (!valid) wx.utils.toast('请选择身份证正反面照片')
    return valid
  },
  // 选择并上传身份证照片
  uploadPicture(ev) {
    console.log(ev.mark.type);
    // ev.mark.type 如果是idcardFrontUrl，代表选择身份证正面照片
    // ev.mark.type 如果是idcardBackUrl，代表选择身份证反面照片
    // 选择图片
    wx.chooseMedia({
      count: 1,
      mediaType: ['image'],
      sizeType: ['compressed'],
      success: (res) => {
        console.log(res.tempFiles[0].tempFilePath);
        // 将小程序的临时图片地址，上传到服务器，获取到服务器返回的线上图片地址
        wx.uploadFile({
          url: wx.http.baseURL + '/upload',
          filePath: res.tempFiles[0].tempFilePath,
          name: 'file',
          header: {
            Authorization: getApp().token
          },
          success: (res) => {
            console.log(JSON.parse(res.data).data.url);
            const url = JSON.parse(res.data).data.url
            if (ev.mark.type === 'idcardFrontUrl') {
              // 点击的是身份证正面
              this.setData({
                idcardFrontUrl: url
              })
            } else {
              // 点击的是身份证反面
              this.setData({
                idcardBackUrl: url
              })
            }
          }
        })
      }
    })
    
  },
  // 点击提交审核
  async submitForm() {
    // 校验姓名
    if (!this.validName()) return
    // 校验手机号
    if (!this.validMobile()) return
    // 校验身份证照片
    if (!this.validPicture()) return 
    // 删除this.data中的多余属性
    delete this.data.__webviewId__
    delete this.data.status

    // 发送接口请求，完成添加房屋功能
    const { code } = await wx.http.post('/room', this.data)
    if (code !== 10000) return wx.utils.toast()
    // 请求成功，跳转到房屋列表页
    wx.navigateBack({ delta: this.data.id ? 2: 4 })
    
  }
})